草庐IT

c++ - R 和 C++ 迭代

全部标签

c++ - 像迭代器一样编写 STL

我试图学习像迭代器一样编写STL,为此我编写了一个简单的循环数组并在其中添加了一个迭代器。请查看代码底部以查看问题。templateclassRingQueue{T*_marray;int_mbegin;int_msize;public:RingQueue(){_marray=newT[N];_mbegin=0;_msize=0;}voidpush_back(constT&val){if(_msize!=N){_marray[(_mbegin+_msize)%N]=val;_msize++;}elsethrow"QueueFull";}Tpop_front(){if(_msize!=0

c++ - c++ STL迭代器的混淆使用

当我像这样使用迭代器时,//includeheaderfilesusingnamespacestd;intmain(){mapintIntMap;map::iteratorpos;pos=intIntMap.begin();intIntMap[0]=1;intIntMap[3]=5;intIntMap[4]=9;intIntMap[5]=5;//遍历coutfirst"second输出为4;但是当我这样使用迭代器时://includeheaderfileusingnamespacestd;intmain(){mapintIntMap;map::iteratorpos;intIntMap

c++ - 使用迭代器从 boost 多索引中删除项目时的一致性

我知道下面的代码对于std::vectors和更普遍的所有STL容器来说是不正确的:std::vector::iteratorit=array.begin();for(;it!=array.end();it++){...array.erase(it);...}因为删除元素后需要更新迭代器。我想知道boost多索引是否相同,例如,下面的内容是否正确:my_index::iteratorit=index.get().begin();for(;it!=index.get().end();it++){...index.erase(it);...}我想确保理解文档的以下段落:http://www

类中的 C++ 迭代器

我有以下类(class):classlist{private:structnode{node(){data=T();prev=next=this;}˜node(){}Tdata;node*prev;node*next;};public:classiterator{public:iterator():p(NULL){}T&operator*(){returnp->data;}iterator&operator++(){p=p->next;return*this;}iterator&operator++(int){iteratortmp=*this;++*this;return*tmp;}

c++ - 一对开始和结束迭代器——它有名字吗?

在C++中,是否定义了表示一对迭代器的struct(或类)——一个开始迭代器,一个结束迭代器?代表这一点的最佳做法是什么?标准::对?我知道我自己可以很容易地构建它,但我想遵循常见的做法。我搜索以下内容:templatestructXXX{private:Itb;Ite;public:Itbegin()const{returnb;}Itend()const{returne;}//...}; 最佳答案 如果它是一对两个任意迭代器,那就是-一对迭代器。如果它恰好是一对迭代器,某些假设成立,例如“它们指向同一个容器”,我会称它为“范围”,

c++ - 我总是可以用常规指针代替输入迭代器吗?

我能否始终以下面代码中示例的方式替换InputIterators的指针?inta[]={5,6,7,8,9,10};std::listl(a,a+4);//5,6,7,8list的构造函数声明是(省略分配器部分)list(InputIteratorfirst,InputIteratorlast);但是从C++引用来看,似乎任何支持++(递增)和*(取消引用)等操作的东西都可以用作InputIterators?谢谢。 最佳答案 C++标准部分§24.2.1[iterator.requirements.general]:Iterator

c++ - 内存分配和字符数组

我还是不太明白,到底会发生什么情况:inti=0;for(i;isome_array会充当:some_array=malloc(24);在循环的开始和free(some_array)在循环结束时?或者那些变量会在栈中分配,函数结束后销毁? 最佳答案 some_array对于block是局部的,因此它在循环的每次迭代开始时创建,并在循环的每次迭代结束时再次销毁。对于一个简单的数组,“创建”和“销毁”意义不大。如果(在C++中)您将它替换为(例如)一个在创建和销毁时打印出某些内容的对象,您会看到这些副作用发生了。

c++ - 在 C++ 中,是否可以实现推进使 "current"元素无效的迭代器接口(interface)?

我正在设计一个C++接口(interface),允许用户迭代从文件解码的对象。这个解码过程有点慢。我正在考虑为此使用迭代器接口(interface),但我想避免任何不必要的复制,所以我正在考虑(用户方面):for(constauto&object:file){//youcanaccessthemembersof`object`herestd::cout前面使用示例中的object是对迭代器实例内部对象的引用。这是错的吗?您会在这里建议哪些其他惯用界面?我想到了一个流接口(interface)(想想std::istream),但是据我所知,读取数据的方法也返回拷贝(它们提取字符)。

c++ - C++ STL 函数 find() 不接受用户定义类的迭代器参数

当我在std::find()中传递用户定义的迭代器参数时,GCC5.2.1。编译器(在Ubuntu15.10上)给出两条错误消息:(1)/usr/include/c++/5/bits/stl_algo.h:162:34:error:nomatchingfunctionforcallto‘__iterator_category(Text_iterator&)’std::__iterator_category(__first));(2)/usr/include/c++/5/bits/stl_iterator_base_types.h:204:5:error:notypenamed‘iter

c++ - 在 C++ 中是否有 "generic"迭代器类型用于函数参数?

我有一个包含std::list的C++类作为成员(member)。现在我想添加一个方法,可用于将另一个容器的值插入到该列表中。像这样:templateclassBeliefSet{std::listm_List;voidSetFacts(???IterBegin,???IterEnd){m_List.insert(m_List.end(),IterBegin,IterEnd);}};现在我的问题是:我必须替换什么???with,以便它可以采用任何(或至少最常见的)std的迭代器容器,例如list,vector,ETC。?我用std::iterator试过了,但这似乎不起作用。请注意,这